MkTabbed
PyMdown-based Tab container.¶
Example: Regular¶
Some markdown
Other Markdown
<div class="tabbed-set" data-tabs="1:2"><input checked id="__tabbed_1_1" name="__tabbed_1" type="radio"><label for="__tabbed_1_1">Tab 1</label><div class="tabbed-content">
<p>Some markdown</p>
</div>
<input id="__tabbed_1_2" name="__tabbed_1" type="radio"><label for="__tabbed_1_2">Tab 2</label><div class="tabbed-content">
<p>Other Markdown</p>
</div>
</div>
Example: Nested¶
Jinja
Some markdown
Other Markdown
Info
Nested admonition
Some markdown
Other Markdown
Info
Nested admonition
<div class="tabbed-set" data-tabs="1:2"><input checked id="__tabbed_1_1" name="__tabbed_1" type="radio"><label for="__tabbed_1_1">Tab 1</label><div class="tabbed-content">
<p>Some markdown</p>
</div>
<input id="__tabbed_1_2" name="__tabbed_1" type="radio"><label for="__tabbed_1_2">Tab 2</label><div class="tabbed-content">
<p>Other Markdown</p>
</div>
</div>
<div class="admonition info">
<p class="admonition-title">Info</p>
<p>Nested admonition</p>
</div>
<div class="tabbed-set" data-tabs="2:2"><input checked id="__tabbed_2_1" name="__tabbed_2" type="radio"><label for="__tabbed_2_1">Tabs</label><div class="tabbed-content">
<div class="tabbed-set" data-tabs="3:2"><input checked id="__tabbed_3_1" name="__tabbed_3" type="radio"><label for="__tabbed_3_1">Tab 1</label><div class="tabbed-content">
<p>Some markdown</p>
</div>
<input id="__tabbed_3_2" name="__tabbed_3" type="radio"><label for="__tabbed_3_2">Tab 2</label><div class="tabbed-content">
<p>Other Markdown</p>
</div>
</div>
</div>
<input id="__tabbed_2_2" name="__tabbed_2" type="radio"><label for="__tabbed_2_2">Admonition</label><div class="tabbed-content">
<div class="admonition info">
<p class="admonition-title">Info</p>
<p>Nested admonition</p>
</div>
</div>
</div>
MkContainer
├── MkTabbed(tabs=[...])
│ ├── MkTab(title='Tab 1', content='Some markdown', new=True)
│ │ ╰── MkText('Some markdown')
│ ╰── MkTab(title='Tab 2', content='Other Markdown')
│ ╰── MkText('Other Markdown')
├── MkAdmonition('Nested admonition')
│ ╰── MkText('Nested admonition')
╰── MkTabbed(tabs=[...])
├── MkTab(title='Tabs', content=MkTabbed(tabs=[...]), new=True)
├── MkTabbed(tabs=[...])
│ ├── MkTab(title='Tab 1', content='Some markdown', new=True)
│ │ ╰── MkText('Some markdown')
│ ╰── MkTab(title='Tab 2', content='Other Markdown')
│ ╰── MkText('Other Markdown')
│ ╰── MkTab(title='Admonition', content=MkAdmonition('Nested admonition'))
├── MkAdmonition('Nested admonition')
│ ╰── MkText('Nested admonition')
Name | Children | Inherits |
---|---|---|
MkTabContainer mknodes.basenodes.mktabcontainer Base class for nodes containing tabs. |
graph TD
93860742990720["mktabbed.MkTabbed"]
93860738698096["mktabcontainer.MkTabContainer"]
93860744077920["mkcontainer.MkContainer"]
93860744073616["mknode.MkNode"]
93860744080896["node.Node"]
140589822947552["builtins.object"]
93860738698096 --> 93860742990720
93860744077920 --> 93860738698096
93860744073616 --> 93860744077920
93860744080896 --> 93860744073616
140589822947552 --> 93860744080896
/home/runner/work/mknodes/mknodes/mknodes/basenodes/mktabbed/metadata.toml
[metadata]
name = "MkTabbed"
icon = "mdi:tab"
[requirements.extension."pymdownx.tabbed"]
[requirements.extension."pymdownx.superfences"]
[examples.regular]
title = "Regular"
jinja = """
{{ {"Tab 1": "Some markdown", "Tab 2": "Other Markdown"} | MkTabbed}}
"""
[examples.nested]
title = "Nested"
jinja = """
{% set node = {"Tab 1": "Some markdown", "Tab 2": "Other Markdown"} | MkTabbed %}
{{ {"Tabs": node, "Admonition": mk.MkAdmonition("Nested admonition")} | MkTabbed }}
"""
[fragments.tab]
template = """
==={% if tab.new %}!{% endif %}{% if tab.select %}+{% endif %} "{{ tab.title }}"
{{ tab.items | join(tab.block_separator) | rstrip("\n") | indent }}
{% if tab.annotations %}
{ .annotate }
{{ tab.annotations | indent }}
{% endif %}
"""
[output.markdown]
template = """
{{ node.items | join(node.block_separator) }}
"""